# EE 52

## **Spring** 2017

# Digital Oscilloscope Documentation

Sophia Liu

December 16, 2017

# Contents

| 1            | Use                     | r Manual                           |  |  |  |  |  |  |  |
|--------------|-------------------------|------------------------------------|--|--|--|--|--|--|--|
|              | 1.1                     | System Description                 |  |  |  |  |  |  |  |
|              | 1.2                     | How to Use the System              |  |  |  |  |  |  |  |
|              | 1.3                     | System Settings                    |  |  |  |  |  |  |  |
|              |                         | 1.3.1 Menu                         |  |  |  |  |  |  |  |
|              |                         | 1.3.2 Rotary Encoder Functionality |  |  |  |  |  |  |  |
| 2            | Technical Documentation |                                    |  |  |  |  |  |  |  |
|              | 2.1                     | Hardware                           |  |  |  |  |  |  |  |
|              |                         | 2.1.1 Hardware System Overview     |  |  |  |  |  |  |  |
|              |                         | 2.1.2 Power                        |  |  |  |  |  |  |  |
|              |                         | 2.1.3 Analog System                |  |  |  |  |  |  |  |
|              |                         | 2.1.4 Rotary Encoders              |  |  |  |  |  |  |  |
|              |                         | 2.1.5 VRAM and LCD                 |  |  |  |  |  |  |  |
|              |                         | 2.1.6 Memory                       |  |  |  |  |  |  |  |
|              |                         | 2.1.7 FPGA                         |  |  |  |  |  |  |  |
|              |                         | 2.1.8 JTAG, Reset, and Clock 1     |  |  |  |  |  |  |  |
|              |                         | 2.1.9 Fixes                        |  |  |  |  |  |  |  |
|              | 2.2                     | Software                           |  |  |  |  |  |  |  |
|              |                         | 2.2.1 Software System Overview     |  |  |  |  |  |  |  |
|              |                         | 2.2.2                              |  |  |  |  |  |  |  |
| $\mathbf{A}$ | Coc                     | e 19                               |  |  |  |  |  |  |  |
| В            | Tim                     | ing Diagrams 23                    |  |  |  |  |  |  |  |
|              | B.1                     | ADC                                |  |  |  |  |  |  |  |
|              | B.2                     | LCD                                |  |  |  |  |  |  |  |
|              | B.3                     | ROM and RAM                        |  |  |  |  |  |  |  |

| B.4 | VRAM . |  |  |  |  |  |  |  |  |  |  |  | 4 | 27 |
|-----|--------|--|--|--|--|--|--|--|--|--|--|--|---|----|
|     |        |  |  |  |  |  |  |  |  |  |  |  |   |    |

#### 1 User Manual

#### 1.1 System Description

The System on Programmable Chip (SoPC) Digital Oscilloscope is an FPGA/microprocessor-based system capable of capturing and displaying up to 5 MHz signals. The analog input can range from 0 V to 3.8 V. The system has all the features of a standard oscilloscope with the exception of input signal scaling. Two rotary encoders are used to control the settings, and a LCD display is used to display the captured signal.

#### 1.2 How to Use the System

The system will begin immediately upon powering up. <sup>1</sup> The system starts in one-shot trace mode with a sampling rate of 100 ns, a mid-level trigger (halfway between the minimum and maximum trigger levels, at 1.9 V) with no delay and positive slope, and with the menu displayed and scale set to axes. The probe can be attached to the desired input source. The oscilloscope settings are described in section 1.3. The reset button can be used to restart the system.

#### 1.3 System Settings

#### 1.3.1 Menu

The scope parameter menu is located in the upper right corner of the LCD and contains the following entries in order:

Mode
Scale
Sweep
Trigger
Level
Slope
Delay

The menu display can be toggled on and off by pressing the menu rotary encoder. The user can cursor to any of the entries by turning the menu rotary encoder and can change a setting by turning the secondary rotary encoder. Changes take effect

<sup>&</sup>lt;sup>1</sup> The serial configuration device currently does not work, so the FPGA must first be programmed through the JTAG debugger.

immediately. More rotary details can be found in section 1.3.2. The menu entries are described in more detail below.

Mode: The Mode menu entry can be set to Mode Normal, Mode Automatic, or Mode One-Shot. In Mode Normal the scope waits for another trigger after every retrace. In this mode, new traces are captured as fast as the scope can redraw the screen. Mode Automatic works the same as Mode Normal if there are trigger events. But if no trigger event occurs after a specified delay (typically significantly longer than the time represented by a screen of data) the scope triggers automatically without a trigger event occurring. In Mode One-Shot the scope triggers only once and then holds that trace on the screen. It does not look for another trigger event until the Trigger menu item is selected and secondary rotary encoder is turned.

Scale: The Scale menu entry can be set to Scale Axes, Scale Grid, or Scale Off. If the scale is set to Scale Axes, the x and y axes are displayed along with the trace. If the scale is set to Scale Grid, an x-y grid is displayed along with the trace. If the scale is set to Scale Off, no axes or grid are displayed.

Sweep: The Sweep menu entry sets the sweep rate (in time per sample) for the scope. Possible settings are: 100, 200, and 500 nanoseconds, and 1, 2, 5, 10, 20, 50, 100, 200, and 500 microseconds, and 1, 2, 5, 10, and 20 milliseconds (per sample).

Trigger: The Trigger menu entry re-arms the trigger for the scope in one-shot mode. Any time it is selected and the secondary rotary encoder is turned the scope trigger is re-armed and a new trace will then be captured once the trigger conditions (level and slope) are met.

Level: The Level menu entry sets the trigger level. It can be set to any value from the most negative input voltage to the most positive in 128 steps. Additionally, the trigger level is displayed as a line on the screen when the trigger level is being changed.

Slope: The Slope menu entry is either Slope + or Slope - and determines whether the scope is triggered on a positive or negative slope respectively.

Delay: The Delay menu entry determines the trigger delay. It sets the time after the trigger event at which the trace will start. It may be set to any value from the minimum delay to the maximum delay times the sample rate and it is displayed as a time.

#### 1.3.2 Rotary Encoder Functionality

The user can change the scope configuration via two rotary encoders (seen in ??). All of the scope parameters are set via an on-screen menu. The rotary actions are detailed below:

Press encoder 1: Turns the menu on/off. If the menu is off it is not displayed and turning the rotary encoders have no effect on the settings.

Turn encoder 1 CW: Moves the cursor down, if not already at the bottom menu item. If at the bottom, the cursor does not move.

Turn encoder 1 CCW: Moves the cursor up, if not already at the top menu item. If at the top, the cursor does not move.

Turn encoder 2 CW: Changes the currently selected (with cursor) menu item. Goes "forward" through the list of possible settings. If at the "end" of the list, doesn't change the current selection.

Turn encoder 2 CCW: Changes the currently selected (with cursor) menu item. Goes "backward" through the list of possible settings. If at the "beginning" of the list, doesn't change the current selection.

#### 2 Technical Documentation

#### 2.1 Hardware

#### 2.1.1 Hardware System Overview

The oscilloscope system is centered around a Cyclone III FPGA, which includes a Nios II CPU and controllers for the VRAM, LCD, rotary encoders, and analog input and triggering. Upon startup, the bitmap is loaded from the serial EEPROM. The is then loaded from the ROM.

Receiving a Signal: When the probe is connected to a desired input, the analog signal is sent to an Analog to Digital Converter chip. 8 bits of data are then sent in parallel to the FPGA to an analog controller.

The various trigger setting inputs (auto triggering, trigger enable, trigger slope, trigger level) are used along with the 8 bit signal to determine if the system should begin sampling. Once triggering has occurred, the signal is written to a FIFO buffer at the sampling rate. Once the FIFO is full, the CPU clocks out and stores the buffer data to be displayed.

Displaying a Signal:

In order to display the signal on the LCD, data is written to the VRAM, which is then sent out to the LCD. Several control signals (write enable, chip select, address, wait) are sent from the CPU to the VRAM controller to perform read and write operations on the VRAM. A (moore??) state machine is used to generate

#### 2.1.2 Power

A din4 connector (PWR1) is used to supply the board with +/-12 V and 5 V. All chips are locally bypassed (...?)

5 V is used to power the reset, VRAM, SRAM, ROM, and ADC chips.

Several LM1086 regulators are used to generate the other required voltages. Specifically, U14 uses the 5 V supply to generate 2.5 V for analog power to the FPGA PLLs, and U15 uses the 5 V supply to generate 1.2 V for FPGA power supply and digital power to the FPGA PLLs. U16 generates 3.3 V from 5 V, which is used to power the FPGA I/O supply pins, buffers, JTAG, serial configuration device, clock, and for pulling high the rotary encoders. (??)

Regulators also generate 5 V from 12 V (U24) and 4 V from 5 V (U23) for ADC reference voltages. (more analog stuff in analog section?)

A boost converter is used to generate the 25 V necessary for the LED backlight. U21 (part number AP3012) steps up from 5 V and outputs 25 V. (more detail? was used because?)

#### 2.1.3 Analog System

The analog input can range from 0 to 4 V. An analog-to-digital converter (U17, TLC5510A) was used to digitize the input signal to 8 bits. This was chosen because of the simplicity of the circuit needed in order to meet the 0-3 V requirement.

Several analog supply voltages were used to isolate the analog and digital circuitry. An external 4 V analog reference was generated and used for a 0-4 V range for the input signal. A 5 V analog supply voltage was also required, along with an analog ground reference connected to digital ground through an inductor.

Analog logic:

Analog inputs:

Several values are taken as outputs from the software and are used in the hardware logic. Specifically, an 8 bit trigger level, 1 bit auto triggering, 1 bit trigger slope, 1 bit trigger enable, 19 bit sampling rate, and 16 bit trigger delay are used.

Trigger logic:

First, the system determines whether or not a trigger has occurred. A Moore state machine is used to determine whether or not a trigger has occurred. It sets the trigger event signal high when the trigger slope is positive and the signal has transitioned from below to above the trigger level, or if the trigger slope is negative and the signal has transitioned from above to below the trigger level. The code can be found in Appendix ??.

Thus, the 8-bit signal is compared to the trigger level, and the less than and equal to outputs are sent to the trigger state machine along with the trigger slope.

The system also generates a trigger event if auto trigger is enabled after 512 clocks, which was arbitrarily chosen as a short amount of time.

A counter and comparator are used to create a clock at the given sampling rate. Once a trigger event has occurred, another counter and comparator are used to create the trigger delay. The signal is then written into a FIFO buffer at the sampling rate, which is clocked out through the software when it is full. The FIFO has a size of 480 words, or the length of the LCD.

#### 2.1.4 Rotary Encoders

Two rotary encoders are used for the user input. These include and A and B output for the encoder and a single pull single throw push button switch.

Pins A and B are pulled high<sup>2</sup>, while the common pin is grounded

<sup>&</sup>lt;sup>2</sup>1 K resistors were used in place of the 10 K resistors on the schematic because the voltage high output was too low for the buffers.

to create out-of-phase pulses from outputs A and B.

Rotary decoder logic:

The rotary logic block consists of a debouncer for the push button and a decoder for the rotary encoder.

The debouncer (AnalogDebounce) takes as inputs the active-low button input (Rotary1\_P and Rotary2\_P on the schematic), clock, and active-low reset signal. It outputs a single active-high clock pulse whenever the button input signal is low for longer than 100000 clocks, which was chosen through testing the switches.

The decoder (RotaryController) takes as inputs the two active-low outputs from the encoder (Rotary1\_A and Rotary1\_B, and Rotary2\_A and Rotary2\_B on the schematic), and the reset and clock signals, and outputs a single active-high clock pulse for each counter-clockwise turn of the rotary encoder, where output A leads B.

This is accomplished by first debouncing the input using a counter and comparator to eliminate glitches. Several DFFs are used in series in order to read inputs A and B from two consecutive clocks to determine when edges have occurred. An SRFF is set low when input B goes from low to high while input A is still low, and is set high otherwise. The inverse of this is returned as the output, resulting in a decoder for one direction. Two decoders are used for each rotary encoder to distinguish clockwise and counterclockwise turns.

#### 2.1.5 VRAM and LCD

Two 256Kx4 DRAM with 512x4 SAM (serial access memory) chips (U19, U22, MT42C4225) were used for a total of 8 bits of data, with a 480x272 RGB TFT LCD (Connector J2, ERTFT043-3).

VRAM: Each VRAM sends 4 bits of serial data to the LCD, and receives 4 bits of data from the CPU, along with a 9 bit address and row address strobe (RAS), column address strobe (CAS), write enable (WE), and output enable (OE) signals from the VRAM controller. A serial clock signal is also sent to the VRAM. The LCD controller generates the various clock signals that are sent to synchronize the VRAM and LCD.

The VRAM consists of the DRAM, transfer circuitry, and SAM. Read and write cycles are performed to read and write to the

DRAM, and read transfer cycles are performed to transfer a row from the DRAM to SAM. The VRAM is refreshed when no other operations are being performed to retain data.

The two chips are sent the same control and address signals, and receive and output different data signals.

memory,sam stuff

LCD: The LCD receives 8 bits of data in parallel from the DRAM, 3 bits of red, 3 bits of green, and 2 bits of blue, with the unused color bits pulled down. It also receives a horizontal sync, vertical sync, clock, and data enable signal from the LCD controller. The touch inputs were unused.

The LCD also required a 25V backlight supply (VLED on the schematic). A step-up converter (U21) was used, which is discussed in more detail in Section 2.1.2.

Logic overview: The VRAM-LCD system consists of a VRAM controller and LCD controller that interact with each other, the CPU, and the VRAM and LCD.



Figure 1: Block Diagram for VRAM and LCD.



Figure 2: VRAM and LCD Controllers.

VRAM Controller:

The VRAM controller takes several inputs from the CPU: 1-bit chip select and write enable signals, and an 18-bit address. It also takes as an input a transfer request signal from the display controller. A state machine is used to generate the output signals, the RAS, CAS, address selector, WE, OE, serial clock, CPU wait output, and transfer acknowledge signals.



Figure 3: VRAM Controller.

The output address is selected and outputted using a multiplexer. For either the column or row, the first or second half of the input address, is returned. In the case of a row transfer the SAM start address, 0 for the beginning of the SAM, and the current row, are outputted at the appropriate times. A counter is used to increment the current row for after each row transfer cycle, from row 0 to 272, or the total width of the LCD.

The read, write, row transfer, and refresh cycles are performed with a Moore state machine. transfer/acknowledge with row transfer

The state machine begins at an idle state, and goes back to the idle state after each cycle is completed. If there is a row transfer request, when the transfer flag is active, the row transfer cycle is performed. If there is a write request, when the chip select and write enable inputs are active, then the write cycle is performed. If there is a read select, when the chip select is enabled but write enable is not, then the read cycle is performed. If none of these cycles are to be completed when in the idle state, a refresh cycle is performed.

Timing diagrams were used to create the state machine with the correct outputs, found in Appendix B.

LCD Controller:

The LCD controller is used to generate the clock signals for the LCD.

The Vertical Sync (VSYNC) signal is used for changing rows, and Horizontal Sync (HSYNC) for changing columns. The Data Enable (DE) signal is also generated for when input data is valid within the VSYNC AND HSYNC signals. A 12 MHz clock signal is also sent to the LCD, while a serial clock signal is generated for the VRAM clock input to the serial address counter for the SAM registers.

The timing diagrams can be found in Appendix B, Figures 11 and 12.



Figure 4: LCD Controller, with comparators for defining valid regions in the signals.

# 2.1.6 Memory

Memory Map:



Figure 5: Memory map diagram, used by the CPU(?)

ROM: 1 512 K x 8 bit EEROM (U2, Am29F040) was used. 8 data bits are connected in parallel through the buffers to the CPU, along with 19 address bits, an active-low chip enable (CE), and output enable (OE) signal. The write enable (WE) signal was pulled up, as the ROM was written to with a dedicated ROM programmer.

The ROM timing diagram for the read cycle can be seen at Appendix B, Figure 13. 3 read wait states were used.

The executable file from the Nios II IDE was loaded into it using the ROM programmer.



Figure 6: ROM Schematic.

#### SRAM: 1 128 K x 8 bit CMOS static RAM was used (U1, HM628128B)

The address line is shared between the ROM and SRAM, with only the 17 least significant bits used for RAM addressing. The 8-bit data bus is also shared between the ROM and SRAM. The active-low output enable (OE), write enable (WE), and chip select (CS1) are also connected between the SRAM and CPU, with the second active high chip select (CS2) pulled high as required by the read and write cycles.

The SRAM timing diagrams can be seen at Appendix B, Figures 14 and 15. 2 read wait states and 1 write wait state was used.



Figure 7: SRAM Schematic.

Serial EEPROM: A serial configuration device (U4, EPCS16), a 2 MB flash memory device, was used to store FPGA configuration data  $^3$ .



Figure 8: EEPROM Schematic.

 $<sup>^3</sup>$  Was unable to successfully use serial device for unknown reasons, possibly due to incorrect FPGA configurations.

An Altera Cyclone III FPGA was used (U9, EP3C25Q240). The three required voltage levels were generated with regulators, and each power pin was locally bypassed.

Buffers, or level shifters, were used to connect the buses and control signals from the peripheral chips to the FPGA to go between the low FPGA voltage and mainly 5V environment (U5, U6, U7, U8, U10, U12, 74LVT16245). A separate buffer was used to interface with the ADC (U17, TLC5510A), which had a larger input voltage range requirement (U18, SN74HCT240).

The pins were connected on the PCB as listed in Figure ??.

The final product included several changes. Pin 162, an output for device configuration, was left floating, and the reset input was changed to Pin 187. One buffer was also left unusable, resulting in rewiring to extra I/O pins.

To Direction Location I/O Bank VREF Group Fitter Location ADC\_clk Output PIN\_240 8 B8\_N0 PIN\_240 ADC\_db[7] Input PIN\_230 8 B8\_N0 PIN\_230 ADC\_db[6] Input PIN\_233 8 B8\_N0 PIN\_233 ADC\_db[5] Input PIN\_234 8 B8\_N0 PIN\_234 ADC\_db[4] Input PIN\_235 8 B8\_N0 PIN\_235 ADC\_db[3] Input PIN\_236 8 B8\_N0 PIN\_236 ADC\_db[2] Input PIN\_237 8 B8\_N0 PIN\_237 ADC\_db[1] Input PIN\_238 8 B8\_N0 PIN\_238 ADC\_db[0] Input PIN\_239 8 B8\_N0 PIN\_239 altera\_reserved\_tck Input PIN\_27 altera\_reserved\_tdi Input PIN\_26 altera\_reserved\_tdo Output PIN\_29 altera\_reserved\_tms Input PIN\_28 Clock Input PIN\_31 1 B1\_N0 PIN\_31 LCD\_dclk Output PIN\_167 6 B6\_N0 PIN\_167 LCD\_DE Output PIN\_171 6 B6\_N0 PIN\_171 LCD\_hsync Output PIN\_168 6 B6\_N0 PIN\_168 LCD\_vsync Output PIN\_169 6 B6\_N0 PIN\_169 PFO Input PIN\_164 6 B6\_N0 PIN\_164 RAMROM\_ab[18] Output PIN\_39 2 B2\_N0 PIN\_39 RAMROM\_ab[17] Output PIN\_37 2 B2\_N0 PIN\_37 RAMROM\_ab[16] Output PIN\_38 2 B2\_N0 PIN\_38 RAMROM\_ab[15] Output PIN\_44 2 B2\_N0 PIN\_44 RAMROM\_ab[14] Output PIN\_41 2 B2\_N0 PIN\_41 RAMROM\_ab[13] Output PIN\_49 2 B2\_N0 PIN\_49 RAMROM\_ab[12] Output PIN\_43 2 B2\_N0 PIN\_43 RAMROM\_ab[11] Output PIN\_52 2 B2\_N0 PIN\_52 RAMROM\_ab[10] Output PIN\_55 2 B2\_N0 PIN\_55 RAMROM\_ab[9] Output PIN\_51 2 B2\_N0 PIN\_51 RAMROM\_ab[8] Output PIN\_50 2 B2\_N0 PIN\_50 RAMROM\_ab[7] Output PIN\_45 2 B2\_N0 PIN\_45 RAMROM\_ab[6] Output PIN\_46 2 B2\_N0 PIN\_46 RAMROM\_ab[5] Output PIN\_6 1 B1\_N0 PIN\_6 RAMROM\_ab[4] Output PIN\_9 1 B1\_N0 PIN\_9

RAMROM\_ab[3] Output PIN\_13 1 B1\_N0 PIN\_13 RAMROM\_ab[2] Output PIN\_18 1 B1\_N0 PIN\_18 RAMROM\_ab[1] Output PIN\_21 1 B1\_N0 PIN\_21 RAMROM\_ab[0] Output PIN\_22 1 B1\_N0 PIN\_22 RAMROM\_db[7] Bidir PIN\_69 3 B3\_N0 PIN\_69 RAMROM\_db[6] Bidir PIN\_70 3 B3\_N0 PIN\_70 RAMROM\_db[5] Bidir PIN\_71 3 B3\_N0 PIN\_71 RAMROM\_db[4] Bidir PIN\_72 3 B3\_N0 PIN\_72 RAMROM\_db[3] Bidir PIN\_73 3 B3\_N0 PIN\_73 RAMROM\_db[2] Bidir PIN\_68 3 B3\_N0 PIN\_68 RAMROM\_db[1] Bidir PIN\_65 3 B3\_N0 PIN\_65 RAMROM\_db[0] Bidir PIN\_64 3 B3\_N0 PIN\_64 Reset Input PIN\_187 7 B7\_N0 PIN\_187 ROM\_CS Output PIN\_5 1 B1\_N0 PIN\_5 ROM\_OE Output PIN\_4 1 B1\_N0 PIN\_4 romram\_db\_dir Output PIN\_76 3 B3\_N0 PIN\_76 rotary\_1\_A Input PIN\_181 7 B7\_N0 PIN\_181 rotary\_1\_B Input PIN\_182 7 B7\_N0 PIN\_182 rotary\_1\_P Input PIN\_183 7 B7\_N0 PIN\_183 rotary\_2\_A Input PIN\_184 7 B7\_N0 PIN\_184 rotary\_2\_B Input PIN\_185 7 B7\_N0 PIN\_185 rotary\_2\_P Input PIN\_186 7 B7\_N0 PIN\_186 SRAM\_CS Output PIN\_63 3 B3\_N0 PIN\_63 SRAM\_OE Output PIN\_57 2 B2\_N0 PIN\_57 SRAM\_WE Output PIN\_56 2 B2\_N0 PIN\_56 VRAM\_ab[8] Output PIN\_132 5 B5\_N0 PIN\_132 VRAM\_ab[7] Output PIN\_126 5 B5\_N0 PIN\_126 VRAM\_ab[6] Output PIN\_131 5 B5\_N0 PIN\_131 VRAM\_ab[5] Output PIN\_128 5 B5\_N0 PIN\_128 VRAM\_ab[4] Output PIN\_127 5 B5\_N0 PIN\_127 VRAM\_ab[3] Output PIN\_120 4 B4\_N0 PIN\_120 VRAM\_ab[2] Output PIN\_119 4 B4\_N0 PIN\_119 VRAM\_ab[1] Output PIN\_118 4 B4\_N0 PIN\_118 VRAM\_ab[0] Output PIN\_133 5 B5\_N0 PIN\_133 VRAM\_ab\_dir Output PIN\_117 4 B4\_N0 PIN\_117 VRAM\_CAS Output PIN\_134 5 B5\_N0 PIN\_134 VRAM\_control\_dir Output PIN\_145 5 B5\_N0 PIN\_145 VRAM\_db[7] Bidir PIN\_80 3 B3\_N0 PIN\_80 VRAM\_db[6] Bidir PIN\_78 3 B3\_N0 PIN\_78 VRAM\_db[5] Bidir PIN\_82 3 B3\_N0 PIN\_82 VRAM\_db[4] Bidir PIN\_81 3 B3\_N0 PIN\_81 VRAM\_db[3] Bidir PIN\_84 3 B3\_N0 PIN\_84 VRAM\_db[2] Bidir PIN\_83 3 B3\_N0 PIN\_83 VRAM\_db[1] Bidir PIN\_88 3 B3\_N0 PIN\_88 VRAM\_db[0] Bidir PIN\_87 3 B3\_N0 PIN\_87 VRAM\_db\_dir Output PIN\_93 4 B4\_N0 PIN\_93 VRAM\_DSF Output PIN\_173 6 B6\_N0 PIN\_173 VRAM\_OE Output PIN\_139 5 B5\_N0 PIN\_139 VRAM\_RAS Output PIN\_135 5 B5\_N0 PIN\_135 VRAM\_SC Output PIN\_142 5 B5\_N0 PIN\_142 VRAM\_SE Output PIN\_143 5 B5\_N0 PIN\_143 VRAM\_WE Output PIN\_137 5 B5\_N0 PIN\_137 WDI Output PIN\_166 6 B6\_N0 PIN\_166 WDO Input PIN\_161 6 B6\_N0 PIN\_161

2.1.8 JTAG, Reset, and Clock

pin 162 used during FPGA startup, can't use for reset

JTAG:

Reset: A reset circuit is used, which includes a microprocessor supervisory device (U3, MAX705). The watchdog input (WDI) is implemented in the main loop, and a voltage divider is used for a power-fail warning at 4 V from the 5 V supply.

Clock:



Figure 9: Reset Circuit Schematic.

The active-low watchdog output, power-fail output, and reset output, and manual reset output are combined for an overall reset signal that is sent to the CPU and various controllers.

#### 2.1.9 Fixes

wrong adc footprint, buffer soldering error, backwards LCD connector

### 2.2 Software

2.2.1 Software System Overview

2.2.2

# A Code

```
Oscilloscope Digital Trigger
    This is an implementation of a trigger for a digital oscilloscope in
    VHDL. There are three inputs to the system, one selects the trigger
     slope and the other two determine the relationship between the trigger
level and the signal level. The only output is a trigger signal which
    indicates a trigger event has occurred.
    The file contains multiple architectures for a Moore state machine
    implementation to demonstrate the different ways of building a state
    machine.
     Revision History:
        13 Apr 04 Glen George
                                      Initial revision.
                   Glen George
                                      Updated comments.
         4 Nov 05
        17 Nov 07
                   Glen George
                                      Updated comments.
        13 Feb 10
                   Glen George
                                      Added more example architectures.
-- bring in the necessary packages
library ieee;
use \quad i\,e\,e\,e\,.\,s\,t\,d\,\lrcorner\,l\,o\,g\,i\,c\,\lrcorner\,1\,1\,6\,4\,.\,a\,l\,l\,\,;
     Oscilloscope Digital Trigger entity declaration
entity ScopeTrigger is
    port (
         TS
                       in
                            std_logic;
                                            -- trigger slope (1 -> negative, 0 -> positive)
                                            -- signal and trigger levels equal
         TEQ
                            std_logic;
                       in
         TLT
                            std_logic;
                                            -- signal level < trigger level
         clk
                      in
                            std_logic;
                                            -- clock
                            std_logic;
                                            -- reset the system
                       in
         TrigEvent :
                       out std_logic
                                            -- a trigger event has occurred
     );
end ScopeTrigger;
     Oscilloscope Digital Trigger Moore State Machine
        State Assignment Architecture
    This architecture just shows the basic state machine syntax when the state
    assignments are made manually. This is useful for minimizing output
     decoding logic and avoiding glitches in the output (due to the decoding
     logic).
architecture assign_statebits of ScopeTrigger is
    subtype states is std_logic_vector(2 downto 0);
                                                              -- state type
    -- define the actual states as constants
                         : states := "000"; -- waiting for start of trigger event
     {\tt constant \ WAIT\_POS \ : \ states := "001"; \ -- \ waiting \ for \ positive \ slope \ trigger}
```

```
constant WAIT_NEG : states := "010"; — waiting for negative slope trigger constant TRIGGER : states := "100"; — got a trigger event
    signal CurrentState : states; -- current state
    signal NextState : states; — next state
begin
    -- the output is always the high bit of the state encoding
    TrigEvent <= CurrentState(2);
    -- compute the next state (function of current state and inputs)
    transition: process (Reset, TS, TEQ, TLT, CurrentState)
    begin
        case CurrentState is
                                         -- do the state transition/output
             when IDLE =>
                                           -- in idle state, do transition
                 if (TS = '0') and TLT = '1' and TEQ = '0') then
                     NextState <= WAIT_POS; -- below trigger and + slope
                 elsif (TS = '1') and TLT = '0' and TEQ = '0') then
                    NextState <= WAIT_NEG;
                                                   -- above trigger and - slope
                 else
                     NextState <= IDLE;
                                                   -- trigger not possible yet
                 end if;
             when WAIT_POS =>
                                             - waiting for positive slope trigger
                 if (TS = '0') and TLT = '1') then
                 NextState <= WAIT.POS; — no trigger yet elsif (TS = '0' and TLT = '0') then
                    NextState <= TRIGGER;</pre>
                                                   -- got a trigger
                 else
                     NextState <= IDLE;
                                                   -- trigger slope changed
                 end if;
                 WAIT.NEG \Rightarrow — waiting for negative slope trigger if (TS = '1' and TLT = '0' and TEQ = '0') then
             when WAIT_NEG =>
                 NextState <= WAIT.NEG; — no trigger yet elsif (TS = '1' and (TLT = '1' or TEQ = '1')) then
                     NextState <= TRIGGER;
                                                  -- got a trigger
                 else
                     NextState <= IDLE;
                                                   -- trigger slope changed
                 end if;
             when TRIGGER =>
                 n TRIGGER => -- in the trigger state
NextState <= IDLE; -- always go back to idle
                             when others =>
                                       NextState <= IDLE;
        end case;
        if Reset = '1' then
NextState <= IDLE;</pre>
                                       reset overrides everythinggo to idle on reset
        end if;
    end process transition;
    -- storage of current state (loads the next state on the clock)
```

# **B** Timing Diagrams

#### B.1 ADC



Figure 10: ADC Timing Diagram

### B.2 LCD



Figure 11: LCD Horizontal Timing Diagram



Figure 12: LCD Vertical Timing Diagram

#### B.3 ROM and RAM



Figure 13: ROM Read Cycle Diagram



Figure 14: RAM Read Cycle Diagram



Figure 15: RAM Write Cycle Diagram

### B.4 VRAM



Figure 16: VRAM Read Cycle Diagram



Figure 17: VRAM Write Cycle Diagram



Figure 18: VRAM Row Transfer Cycle Diagram



Figure 19: VRAM Refresh Cycle Diagram (CAS before RAS)



Figure 20: VRAM Serial Write Cycle Diagram

# $\mathbf{Index}$

| Analog                            | Sweep, 4                               |
|-----------------------------------|----------------------------------------|
| Hardware, 6                       | Trigger, 4                             |
| Logic, 7<br>Appendix, 19          | Power, 6                               |
| Clock, 17                         | Reset, 17, 18<br>ROM, 13               |
| FPGA, 16                          | Rotary Encoder                         |
| JTAG, 17                          | Functionality, 5<br>Rotary Encoders, 7 |
| LCD, 8, 9<br>Controller, 11       | Serial EEPROM, 15<br>Software, 19      |
| memory, 12                        | SRAM, 14                               |
| Menu, 3 Delay, 4 Level, 4 Mode, 4 | Timing, 23 Trigger, 7 Autotrigger, 7   |
| Scale, 4                          | VRAM, 8                                |
| Slope, 4                          | Controller, 10                         |